// pages/splb/splb.js
Page({

  /**
   * 页面的初始数据
   */
  data: {
    baseURL:wx.baseURL,
    rows:[],
    brands:[],
    brandSelected:{},//已选品牌
    brandVisible:false,//品牌弹框的显示和隐藏
    query:{
      brandIds:'',
      sorted:0,//排序
      key:'',///存储搜索关键字
      pageNum:1,
      pageSize:10
    },
    total:0,
    
  },
//输入搜索关键字
inputKey(e){
  this.data.query.key = e.detail.value
},
//清空选择的品牌（重置）
clearBrand(){
  this.setData({
    brandSelected:{}
  })
},
//按品牌搜索（确定）
confimBrand(){
  let brandIds = []
  for(let key in this.data.brandSelected){//取出选择的品牌id
    if(key && this.data.brandSelected[key]) brandIds.push(key)
  }
  this.data.query.brandIds = brandIds.join(',')
  this.refresh(()=>{
    this.setData({
      brandVisible:false,//选择之后关闭弹窗
    })
  })
},



//切换品牌选择状态
changeBrand(e){
  let brandSelected = this.data.brandSelected
  let id = e.currentTarget.dataset.id
  brandSelected[id] = !brandSelected[id]//取反 切换选择状态
  this.setData({
    brandSelected
  })
},
//修改排序方式
changeSorted(e){
  // console.log(e)
  let sorted = e.currentTarget.dataset.sorted
  this.setData({
    'query.sorted':sorted
  })
  this.refresh()//刷新
},
//重新加载，下拉刷新
refresh(next){
  this.data.query.pageNum =1
  this.data.rows=[]
  this.data.total =0
  this.getList(next)
},

//跳转商品详情页面
detail(e) {
  wx.navigateTo({
    url: '/pages/flxq/flxq?productId=' + e.currentTarget.dataset.id,
  })

},
  fhfl(){
    wx.navigateBack({
      data:1
    })    //返回上一页面或多级页面
  },
//显示品牌
changeBrandVisible(){
  let brandSelected = {}
  if(!this.data.brandVisible && this.data.query.brandIds){//打开品牌弹窗
    let brandIds = this.data.query.brandIds.split(',')//用逗号将brandIds进行切割成数组
    for(let i=0;i<brandIds.length;i++){
      brandSelected[brandIds[i]]=true
    }
  }
  this.setData({
    brandVisible:!this.data.brandVisible,
    brandSelected
  })
},


  //获取品牌列表
getBrands(){
  wx.get('/brands').then(res =>{
    this.setData({
      brands:res
    })
  })
},

  getList:function(next){
    wx.get('/products',this.data.query).then(res =>{
      res.rows.forEach((item)=> {//图片切割
        item.img =item.productImgs.split(',')[0]
      });
      this.setData({
        total:res.total,
        rows:this.data.rows.concat(res.rows)
      })
      if(typeof next =='function') next()
    })
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.setData({
      // key:options.key ||' '///基于关键字进行搜索
      'query.brandIds':options.brandIds || '',
      'query.key':options.key ||' '
    })
    this.getBrands()
    this.getList()//获取数据
  },


  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {
    this.refresh(() =>{
      wx.stopPullDownRefresh()
    })
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {
    this.data.query.pageNum ++
    if(this.data.total > this.data.rows.length){
      this.getList()
    }
  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})
